package leetcode;

/**
 * 买卖股票最佳时机含有冷却期
 */
public class Solution58 {

    public int maxProfit(int[] prices) {
        if(prices == null || prices.length < 2){
            return 0;
        }
        //计算数组长度
        int n = prices.length;
        int[][] dp = new int[prices.length][2];
        dp[0][0] = 0;
        dp[0][1] = -prices[0];
        dp[1][0] = Math.max(dp[0][0],dp[0][1] + prices[1]);
        dp[1][1] = Math.max(dp[0][1],-prices[1]);
        //dp[0][0] 表示持有股票
        //dp[0][1] 表示保持卖出股票
        for(int i = 2;i < prices.length;i++){
            dp[i][0] = Math.max(dp[i-1][0],dp[i - 1][1] + prices[i]);
            dp[i][1] = Math.max(dp[i-1][1],dp[i - 2][0]-prices[i]);
        }
        return dp[prices.length - 1][0];
    }

}
